home *** CD-ROM | disk | FTP | other *** search
/ EnigmA Amiga Run 1997 May / EnigmA AMIGA RUN 18 (1997)(G.R. Edizioni)(IT)[!][issue 1997-05][EAR-CD II].iso / ghost / gs403src_gs.lha / gs4.03 / scf.h < prev    next >
C/C++ Source or Header  |  1995-11-05  |  7KB  |  169 lines

  1. /* Copyright (C) 1992, 1995 Aladdin Enterprises.  All rights reserved.
  2.   
  3.   This file is part of Aladdin Ghostscript.
  4.   
  5.   Aladdin Ghostscript is distributed with NO WARRANTY OF ANY KIND.  No author
  6.   or distributor accepts any responsibility for the consequences of using it,
  7.   or for whether it serves any particular purpose or works at all, unless he
  8.   or she says so in writing.  Refer to the Aladdin Ghostscript Free Public
  9.   License (the "License") for full details.
  10.   
  11.   Every copy of Aladdin Ghostscript must include a copy of the License,
  12.   normally in a plain ASCII text file named PUBLIC.  The License grants you
  13.   the right to copy, modify and redistribute Aladdin Ghostscript, but only
  14.   under certain conditions described in the License.  Among other things, the
  15.   License requires that the copyright notice and this notice be preserved on
  16.   all copies.
  17. */
  18.  
  19. /* scf.h */
  20. /* Common definitions for CCITTFax encoding and decoding filters */
  21. #include "shc.h"
  22.  
  23. /*
  24.  * The CCITT Group 3 (T.4) and Group 4 (T.6) fax specifications map
  25.  * run lengths to Huffman codes.  White and black have different mappings.
  26.  * If the run length is 64 or greater, two or more codes are needed:
  27.  *    - One or more 'make-up' codes for 2560 pixels;
  28.  *    - A 'make-up' code that encodes the multiple of 64;
  29.  *    - A 'termination' code for the remainder.
  30.  * For runs of 63 or less, only the 'termination' code is needed.
  31.  */
  32.  
  33. /* ------ Encoding tables ------ */
  34.  
  35. /* Define the maximum length of a scan line that we can encode. */
  36. /* Even though the natural values for this are 2560 * N + 63, */
  37. /* we don't want to impose a limit significantly smaller than max_int. */
  38. #define cfe_max_width 32000
  39. #define cfe_max_makeups (cfe_max_width / 2560)
  40. #define cfe_max_code_bytes (cfe_max_makeups * 2 + 2) /* conservative */
  41.  
  42. typedef hce_code cfe_run;
  43. #define cfe_entry(c, len) hce_entry(c, len)
  44.  
  45. /* Codes common to 1-D and 2-D encoding. */
  46. /* The decoding algorithms know that EOL is 0....01. */
  47. #define run_eol_code_length 12
  48. #define run_eol_code_value 1
  49. extern const cfe_run cf_run_eol;
  50. extern const cfe_run far_data cf_white_termination[64];
  51. extern const cfe_run far_data cf_white_make_up[41];
  52. extern const cfe_run far_data cf_black_termination[64];
  53. extern const cfe_run far_data cf_black_make_up[41];
  54. extern const cfe_run cf_uncompressed[6];
  55. extern const cfe_run cf_uncompressed_exit[10];    /* indexed by 2 x length of */
  56.             /* white run + (1 if next run black, 0 if white) */
  57. /* 1-D encoding. */
  58. extern const cfe_run cf1_run_uncompressed;
  59. /* 2-D encoding. */
  60. extern const cfe_run cf2_run_pass;
  61. #define cf2_run_pass_length 4
  62. #define cf2_run_pass_value 0x1
  63. #define cf2_run_vertical_offset 3
  64. extern const cfe_run cf2_run_vertical[7];    /* indexed by b1 - a1 + offset */
  65. extern const cfe_run cf2_run_horizontal;
  66. #define cf2_run_horizontal_value 1
  67. #define cf2_run_horizontal_length 3
  68. extern const cfe_run cf2_run_uncompressed;
  69. /* 2-D Group 3 encoding. */
  70. extern const cfe_run cf2_run_eol_1d;
  71. extern const cfe_run cf2_run_eol_2d;
  72.  
  73. /* ------ Decoding tables ------ */
  74.  
  75. typedef hcd_code cfd_node;
  76. #define run_length value
  77.  
  78. /*
  79.  * The value in the decoding tables is either a white or black run length,
  80.  * or a (negative) exceptional value.
  81.  */
  82. #define run_error (-1)
  83. #define run_zeros (-2)    /* EOL follows, possibly with more padding first */
  84. #define run_uncompressed (-3)
  85. /* 2-D codes */
  86. #define run2_pass (-4)
  87. #define run2_horizontal (-5)
  88.  
  89. #define cfd_white_initial_bits 8
  90. extern const cfd_node far_data cf_white_decode[];
  91. #define cfd_black_initial_bits 7
  92. extern const cfd_node far_data cf_black_decode[];
  93. #define cfd_2d_initial_bits 7
  94. extern const cfd_node far_data cf_2d_decode[];
  95. #define cfd_uncompressed_initial_bits 6        /* must be 6 */
  96. extern const cfd_node far_data cf_uncompressed_decode[];
  97.  
  98. /* ------ Run detection macros ------ */
  99.  
  100. /*
  101.  * For the run detection macros:
  102.  *   white_byte is 0 or 0xff for BlackIs1 or !BlackIs1 respectively;
  103.  *   data holds p[-1], inverted if !BlackIs1;
  104.  *   count is the number of valid bits remaining in the scan line.
  105.  */
  106.  
  107. /* Aliases for bit processing tables. */
  108. #define cf_byte_run_length byte_bit_run_length_neg
  109. #define cf_byte_run_length_0 byte_bit_run_length_0
  110.       
  111. /* Skip over white pixels to find the next black pixel in the input. */
  112. /* Store the run length in rlen, and update data, p, and count. */
  113. /* There are many more white pixels in typical input than black pixels, */
  114. /* and the runs of white pixels tend to be much longer, so we use */
  115. /* substantially different loops for the two cases. */
  116.  
  117. #define skip_white_pixels(data, p, count, white_byte, rlen)\
  118. { if ( (rlen = cf_byte_run_length[count & 7][data ^ 0xff]) >= 8 )\
  119.     { if ( white_byte == 0 )\
  120.     { if ( p[0] ) { data = p[0]; p += 1; rlen -= 8; }\
  121.       else if ( p[1] ) { data = p[1]; p += 2; }\
  122.       else\
  123.         { while ( !(p[2] | p[3] | p[4] | p[5]) ) p += 4, rlen += 32;\
  124.           if ( p[2] ) { data = p[2]; p += 3; rlen += 8; }\
  125.           else if ( p[3] ) { data = p[3]; p += 4; rlen += 16; }\
  126.           else if ( p[4] ) { data = p[4]; p += 5; rlen += 24; }\
  127.           else /* p[5] */ { data = p[5]; p += 6; rlen += 32; }\
  128.         }\
  129.     }\
  130.       else\
  131.     { if ( p[0] != 0xff ) { data = (byte)~p[0]; p += 1; rlen -= 8; }\
  132.       else if ( p[1] != 0xff ) { data = (byte)~p[1]; p += 2; }\
  133.       else\
  134.         { while ( (p[2] & p[3] & p[4] & p[5]) == 0xff ) p += 4, rlen += 32;\
  135.           if ( p[2] != 0xff ) { data = (byte)~p[2]; p += 3; rlen += 8; }\
  136.           else if ( p[3] != 0xff ) { data = (byte)~p[3]; p += 4; rlen += 16; }\
  137.           else if ( p[4] != 0xff ) { data = (byte)~p[4]; p += 5; rlen += 24; }\
  138.           else /* p[5] != 0xff */ { data = (byte)~p[5]; p += 6; rlen += 32; }\
  139.         }\
  140.     }\
  141.      rlen += cf_byte_run_length_0[data ^ 0xff];\
  142.    }\
  143.   count -= rlen;\
  144. }
  145.  
  146. /* Skip over black pixels to find the next white pixel in the input. */
  147. /* Store the run length in rlen, and update data, p, and count. */
  148.  
  149. #define skip_black_pixels(data, p, count, white_byte, rlen)\
  150. { if ( (rlen = cf_byte_run_length[count & 7][data]) >= 8 )\
  151.    { if ( white_byte == 0 )\
  152.       for ( ; ; p += 4, rlen += 32 )\
  153.       { if ( p[0] != 0xff ) { data = p[0]; p += 1; rlen -= 8; break; }\
  154.     if ( p[1] != 0xff ) { data = p[1]; p += 2; break; }\
  155.     if ( p[2] != 0xff ) { data = p[2]; p += 3; rlen += 8; break; }\
  156.     if ( p[3] != 0xff ) { data = p[3]; p += 4; rlen += 16; break; }\
  157.       }\
  158.      else\
  159.       for ( ; ; p += 4, rlen += 32 )\
  160.       { if ( p[0] ) { data = (byte)~p[0]; p += 1; rlen -= 8; break; }\
  161.     if ( p[1] ) { data = (byte)~p[1]; p += 2; break; }\
  162.     if ( p[2] ) { data = (byte)~p[2]; p += 3; rlen += 8; break; }\
  163.     if ( p[3] ) { data = (byte)~p[3]; p += 4; rlen += 16; break; }\
  164.       }\
  165.      rlen += cf_byte_run_length_0[data];\
  166.    }\
  167.   count -= rlen;\
  168. }
  169.